﻿using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using AccesoDatos.Objetos;
using AccesoDatos.Manejador;

namespace Autorizacion_facturas_caja
{
    public partial class frmVacaciones_Busqueda : Form
    {
        objRH obj = new objRH();
        objVacaciones obj1 = new objVacaciones();
        Manejador_Vacaciones MV = new Manejador_Vacaciones();
        Manejador_Empleado_Captura Mane = new Manejador_Empleado_Captura();

        #region FUNCIONES
        //coloca tips en los botones y manda llamar metodos para el inicio de la forma
        public frmVacaciones_Busqueda()
        {
            InitializeComponent();
            toolTip1.SetToolTip(btnBuscar, "BUSCAR");
            toolTip1.SetToolTip(btnRegresar, "REGRESAR");
            toolTip1.SetToolTip(btnProgramar, "PROGRAMAR");
            toolTip1.SetToolTip(btnPagar, "PAGAR");
            ObtieneDatosCombo();
            buscar();
        }
        //realiza la busqueda 
        private void buscar()
        {
            obj.Buscar = txtBuscar.Text.Trim();
            dataGridView1.DataSource = MV.ListaVacaciones(obj.Buscar, cmbSucursal.SelectedValue.ToString());
            propiedadesColumnas();

        }
        //le da propiedades al datagrid
        private void propiedadesColumnas()
        {
            this.dataGridView1.RowHeadersVisible = false;

            /*Esconde las columnas*/
            this.dataGridView1.Columns["id_empleado"].Visible = false;
            this.dataGridView1.Columns["id_sucursal"].Visible = false;
            this.dataGridView1.Columns["fecha_ingreso"].Visible = false;
            this.dataGridView1.Columns["id_jefe"].Visible = false;
            this.dataGridView1.Columns["cuenta_banco"].Visible = false;
            this.dataGridView1.Columns["estatus"].Visible = false;
            this.dataGridView1.Columns["nombre"].Visible = false;
            this.dataGridView1.Columns["apellidos"].Visible = false;
            this.dataGridView1.Columns["Id_Vacaciones"].Visible = false;
            this.dataGridView1.Columns["Id_Empleado1"].Visible = false;
            this.dataGridView1.Columns["Monto_Dias_Pagados"].Visible = false;
            this.dataGridView1.Columns["Dias_Pagados"].Visible = false;
            this.dataGridView1.Columns["Dias_Disfrutados"].Visible = false;
            this.dataGridView1.Columns["Dias_Programados"].Visible = false;
            this.dataGridView1.Columns["Estatus"].Visible = false;
            this.dataGridView1.Columns["Estatus1"].Visible = false;
            this.dataGridView1.Columns["Referencia"].Visible = false;
            //this.dataGridView1.Columns["id_Relacion_Vacaciones"].Visible = false;
            this.dataGridView1.Columns["Id_Vacaciones"].Visible = false;
            this.dataGridView1.Columns["id_Vacaciones1"].Visible = false;
            this.dataGridView1.Columns["Dias_Restantes"].Visible = false;
            this.dataGridView1.Columns["Dias_Acomulados"].Visible = false;
            this.dataGridView1.Columns["Ciclo"].Visible = false;
            this.dataGridView1.Columns["Monto_Dias_Acomulados"].Visible = false;
            this.dataGridView1.Columns["Fecha_Alta"].Visible = false;
            this.dataGridView1.Columns["Periodo"].Visible = false;
            this.dataGridView1.Columns["id_empresa"].Visible = false;
            this.dataGridView1.Columns["id_departamento"].Visible = false;
            this.dataGridView1.Columns["Monto_Prima"].Visible = false;
            this.dataGridView1.Columns["autorizado"].Visible = false;
            //Renombra columnas

            this.dataGridView1.Columns["Nombre_apellidos"].HeaderText = "EMPLEADO";
            this.dataGridView1.Columns["Antiguedad"].HeaderText = "ANTIGUEDAD";
            this.dataGridView1.Columns["departamento"].HeaderText = "DEPARTAMENTO";
            this.dataGridView1.Columns["Dias_Programados"].HeaderText = "DÍAS PROGRAMADOS";
            this.dataGridView1.Columns["puesto"].HeaderText = "PUESTO";
            //this.dataGridView1.Columns["Seleccionar"].HeaderText = "SELECCIONAR";
            this.dataGridView1.Columns["Dias_Correspondientes"].HeaderText = "DÍAS CORRESPONDIENTES";
            this.dataGridView1.Columns["Dias_Disfrutados"].HeaderText = "DÍAS DISFRUTADOS";
            this.dataGridView1.Columns["Dias_Restantes"].HeaderText = "DÍAS RESTANTES";

            //this.dataGridView1.Columns["Prima_Vacacional"].HeaderText = "Prima Vacacional";
            //this.dataGridView1.Columns["Prima_Vacacional"].DefaultCellStyle.Format = "c";
            //this.dataGridView1.Columns["Prima_Vacacional"].DefaultCellStyle.Alignment= DataGridViewContentAlignment.MiddleRight;
            //this.dataGridView1.Columns["Seleccionar"].DisplayIndex = 0;
            this.dataGridView1.Columns["Nombre_apellidos"].DisplayIndex = 1;
            this.dataGridView1.Columns["departamento"].DisplayIndex = 2;
            this.dataGridView1.Columns["puesto"].DisplayIndex = 3;
            this.dataGridView1.Columns["Antiguedad"].DisplayIndex = 4;
            this.dataGridView1.Columns["Antiguedad"].DefaultCellStyle.Alignment = DataGridViewContentAlignment.MiddleCenter;
            this.dataGridView1.Columns["Dias_Correspondientes"].DisplayIndex = 5;
            this.dataGridView1.Columns["Dias_Correspondientes"].DefaultCellStyle.Alignment = DataGridViewContentAlignment.MiddleCenter;
            this.dataGridView1.Columns["Dias_Disfrutados"].DisplayIndex = 6;
            this.dataGridView1.Columns["Dias_Disfrutados"].DefaultCellStyle.Alignment = DataGridViewContentAlignment.MiddleCenter;
            this.dataGridView1.Columns["Dias_Restantes"].DisplayIndex = 7;
            this.dataGridView1.Columns["Dias_Restantes"].DefaultCellStyle.Alignment = DataGridViewContentAlignment.MiddleCenter;
            this.dataGridView1.Columns["Periodo"].DefaultCellStyle.Alignment = DataGridViewContentAlignment.MiddleCenter;
            this.dataGridView1.Columns["Dias_Programados"].DefaultCellStyle.Alignment = DataGridViewContentAlignment.MiddleCenter;

            this.dataGridView1.Columns["Nombre_apellidos"].HeaderCell.Style.Alignment = DataGridViewContentAlignment.MiddleCenter;
            this.dataGridView1.Columns["Antiguedad"].HeaderCell.Style.Alignment = DataGridViewContentAlignment.MiddleCenter;
            this.dataGridView1.Columns["departamento"].HeaderCell.Style.Alignment = DataGridViewContentAlignment.MiddleCenter;
            this.dataGridView1.Columns["Dias_Programados"].HeaderCell.Style.Alignment = DataGridViewContentAlignment.MiddleCenter;
            this.dataGridView1.Columns["puesto"].HeaderCell.Style.Alignment = DataGridViewContentAlignment.MiddleCenter;
            //this.dataGridView1.Columns["Seleccionar"].HeaderCell.Style.Alignment = DataGridViewContentAlignment.MiddleCenter;
            this.dataGridView1.Columns["Dias_Correspondientes"].HeaderCell.Style.Alignment = DataGridViewContentAlignment.MiddleCenter;
            this.dataGridView1.Columns["Dias_Disfrutados"].HeaderCell.Style.Alignment = DataGridViewContentAlignment.MiddleCenter;
            this.dataGridView1.Columns["Dias_Restantes"].HeaderCell.Style.Alignment = DataGridViewContentAlignment.MiddleCenter;
        }
       //Obtiene los datos de la tabla cat_sucursales al combo de sucursales
        private void ObtieneDatosCombo()
        {
            cmbSucursal.DataSource = Mane.ObtieneSucursales();
            cmbSucursal.ValueMember = "SucId";
            cmbSucursal.DisplayMember = "Nombre";
        }

        #endregion

        #region BOTONES
        //llama al metodo buscar
        private void button1_Click(object sender, EventArgs e)
        {
            buscar();
        }
        //cierra la forma
        private void button2_Click(object sender, EventArgs e)
        {
            Close();
        }
        //despliega la forma para programacion de vacaciones
        private void btnProgramar_Click(object sender, EventArgs e)
        {
            try
            {
                frmVacaciones_Validacion fvv = new frmVacaciones_Validacion(obj, obj1, 1);
                fvv.ShowDialog();
                dataGridView1.DataSource = MV.ListaVacaciones(obj.Buscar, cmbSucursal.SelectedValue.ToString());
                propiedadesColumnas();
            }
            catch { MessageBox.Show("DEBE SELECCIONAR UN EMPLEADO", "ALERTA"); }
            obj.Id_Empleado = 0;
        }
        //despliega la forma para pagar dias de vacaciones
        private void btnPagar_Click(object sender, EventArgs e)
        {
            try
            {
                frmVacaciones_Validacion fvv = new frmVacaciones_Validacion(obj, obj1, 2);
                fvv.ShowDialog();
                dataGridView1.DataSource = MV.ListaVacaciones(obj.Buscar, cmbSucursal.SelectedValue.ToString());
                propiedadesColumnas();
            }
            catch { MessageBox.Show("DEBE SELECCIONAR UN EMPLEADO", "ALERTA"); }
            obj.Id_Empleado = 0;
        }
        //cierra la forma
        private void btnRegresar_Click(object sender, EventArgs e)
        {
            Close();
        }
        #endregion

        #region  EVENTOS
        //llama al metodo buscar
        private void txtBuscar_TextChanged(object sender, EventArgs e)
        {
            buscar();
        }

        //Asigna valores a los objetos de la fila seleccionada
        private void dataGridView1_CellContentClick(object sender, DataGridViewCellEventArgs e)
        {
            try
            {
                obj.Id_Empleado = Convert.ToInt32(dataGridView1[1, e.RowIndex].Value);
                obj.SucId = dataGridView1[2, e.RowIndex].Value.ToString();
                obj.IdJefe = Convert.ToInt32(dataGridView1[3, e.RowIndex].Value);
                obj.Nombre = dataGridView1[4, e.RowIndex].Value.ToString();
                obj.Apellidos = dataGridView1[5, e.RowIndex].Value.ToString();
                obj.Puesto = dataGridView1[6, e.RowIndex].Value.ToString();
                obj.FechaIngreso = Convert.ToDateTime(dataGridView1[7, e.RowIndex].Value);
                obj.Id_Departamento = Convert.ToInt32(dataGridView1[8, e.RowIndex].Value);
                obj.Cuenta_Banco = dataGridView1[9, e.RowIndex].Value.ToString();
                obj.Estatus = Convert.ToInt32(dataGridView1[10, e.RowIndex].Value);
                obj.Nombre_empresa = dataGridView1[11, e.RowIndex].Value.ToString();
                obj1.Id_Vacaciones = Convert.ToInt32(dataGridView1[12, e.RowIndex].Value);
                obj1.Id_Empleados = Convert.ToInt32(dataGridView1[13, e.RowIndex].Value);
                obj1.Antigüedad = Convert.ToInt32(dataGridView1[14, e.RowIndex].Value);
                obj1.Dias_Correspondientes = Convert.ToInt32(dataGridView1[15, e.RowIndex].Value);
                obj1.Dias_Disfrutados = Convert.ToInt32(dataGridView1[16, e.RowIndex].Value);
                obj1.Prima_Vacacional = (dataGridView1[17, e.RowIndex].Value.ToString());
                obj1.Prima_Pagada = dataGridView1[18, e.RowIndex].Value.ToString();
                obj1.Estatus = dataGridView1[19, e.RowIndex].Value.ToString();
                obj1.Dias_Restantes = Convert.ToInt32(dataGridView1[20, e.RowIndex].Value);
                obj1.Dias_Programados = Convert.ToInt32(dataGridView1[21, e.RowIndex].Value);
                obj1.Dias_Acomulados = Convert.ToInt32(dataGridView1[22, e.RowIndex].Value);
                obj1.Referencia = dataGridView1[23, e.RowIndex].Value.ToString();
                obj1.Ciclo = dataGridView1[24, e.RowIndex].Value.ToString();
                obj.Departamento = dataGridView1[30, e.RowIndex].Value.ToString();
            }
            catch { MessageBox.Show("ERROR AL SELECCIONAR EMPLEADO"); }


        }
        
        #endregion


       
       

        

        

        

        

        

       

 



    }
}
